# This Page Is Inserted by IFW Operations and is not a part of the Official Record

# **BEST AVAILABLE IMAGES**

Defective images within this document are accurate representations of the original documents submitted by the applicant.

Defects in the images may include (but are not limited to):

- BLACK BORDERS
- TEXT CUT OFF AT TOP, BOTTOM OR SIDES
- FADED TEXT
- ILLEGIBLE TEXT
- SKEWED/SLANTED IMAGES
- COLORED PHOTOS
- BLACK OR VERY BLACK AND WHITE DARK PHOTOS
- GRAY SCALE DOCUMENTS

# IMAGES ARE BEST AVAILABLE COPY.

As rescanning documents will not correct images, please do not report the images to the Image Problems Mailbox.



### IN THE UNITED STATES PATENT AND TRADEMARK OFFICE

| In re Patent Appli | ication c | of: |
|--------------------|-----------|-----|
|--------------------|-----------|-----|

Toru OKABAYASHI, et al.

Application No.:

**Group Art Unit:** 

Filed: January 28, 2002

Examiner:

For:

MICROCONTROLLER WITH DEBUT SUPPORT UNIT

# SUBMISSION OF CERTIFIED COPY OF PRIOR FOREIGN APPLICATION IN ACCORDANCE WITH THE REQUIREMENTS OF 37 C.F.R. § 1.55

Assistant Commissioner for Patents Washington, D.C. 20231

Sir:

In accordance with the provisions of 37 C.F.R. § 1.55, the applicant(s) submit(s) herewith a certified copy of the following foreign application:

Japanese Patent Application No. 2001-189750

Filed: June 22, 2001

It is respectfully requested that the applicant(s) be given the benefit of the foreign filing date(s) as evidenced by the certified papers attached hereto, in accordance with the requirements of 35 U.S.C. § 119.

Respectfully submitted,

STAAS & HALSEY LLP

Date: <u>January 28, 2002</u>

Ву: \_

James D. Halsey, Jr. Registration No. 22,729

700 11th Street, N.W., Ste. 500 Washington, D.C. 20001 (202) 434-1500



#### 日 国 JAPAN **PATENT OFFICE**

別紙添付の書類に記載されている事項は下記の出願書類に記載されて いる事項と同一であることを証明する。

This is to certify that the annexed is a true copy of the following application as filed with this Office

出願年月日

Date of Application:

2001年 6月22日

出 顧

Application Number:

特願2001-189750

出 人

Applicant(s):

富士通株式会社



2001年 9月 5日

Commissioner, Japan Patent Office





【書類名】

特許願

【整理番号】

0140209

【提出日】

平成13年 6月22日

【あて先】

特許庁長官 殿

【国際特許分類】

G06F 11/22

【発明の名称】

デバッグサポートユニットを有するマイクロコントロー

ラ・

【請求項の数】

10

- 【発明者】

【住所又は居所】

神奈川県川崎市中原区上小田中4丁目1番1号 富士

通株式会社内

【氏名】

岡林 達

【発明者】

【住所又は居所】

神奈川県川崎市中原区上小田中4丁目1番1号 富士

通株式会社内

【氏名】

田川 耕太郎

【特許出願人】

【識別番号】

000005223

【氏名又は名称】

富士通株式会社

【代理人】

【識別番号】

100094525

【弁理士】

【氏名又は名称】 土井 健二

【代理人】

【識別番号】

100094514

【弁理士】

【氏名又は名称】

林 恒▲徳▼

【手数料の表示】

【予納台帳番号】

041380

【納付金額】

21,000円

【提出物件の目録】

【物件名】

明細書 1

【物件名】

図面 1

【物件名】

要約書 1

【包括委任状番号】 9704944

【プルーフの要否】

要

# 【書類名】

# 明細書

【発明の名称】デバッグサポートユニットを有するマイクロコントローラ 【特許請求の範囲】

【請求項1】CPUとバスコントローラを内蔵するマイクロコントローラにおいて、

前記CPUとバスコントローラとを接続する第1のビット数の命令アドレスバス及び命令コードバスと、

前記命令アドレスバスと命令コードバスとが接続されたデバッグサポートユニットとを有し、

前記デバッグサポートユニットは、外部のインサーキットエミュレータに、前 記第1のビット数より少ないビット数のツールバスと該ツールバスのステータス を通知するバスステータス信号線とを介して接続され、

更に, 前記デバッグサポートユニットは,

命令アドレスをパラレル・シリアル変換するパラレル・シリアル変換回路と、 前記CPUから受信した分岐信号と命令フェッチ要求信号に応答して分岐情報 と命令フェッチ要求を有するステータス情報信号を生成するステータス情報生成 回路と、

ステータス情報信号に応答して前記バスステータス信号線に命令アドレス出力 信号を出力するステータス出力回路と,

前記ステータス情報信号に応答して、前記分岐情報が分岐有りの時は前記変換された命令アドレスを前記ツールバスにシリアルに出力し、分岐情報が分岐なしの時は分岐なし信号を前記ツールバスに出力するデータ出力回路とを有することを特徴とするマイクロコントローラ。

【請求項2】請求項1において,

前記データ出力回路は,前記分岐情報が分岐有りの時は,前記変換された命令 アドレスを前記ツールバスに複数サイクルにわたりシリアルに出力し,分岐情報 が分岐なしの時は前記分岐なし信号を前記ツールバスに1サイクルで出力するこ とを特徴とするマイクロコントローラ。

【請求項3】CPUとバスコントローラを内蔵するマイクロコントローラにお

いて、

前記CPUとバスコントローラとを接続する第1のビット数の命令アドレスバス及び命令コードバスと、

前記命令アドレスバスと命令コードバスとが接続されたデバッグサポートユニットとを有し,

前記デバッグサポートユニットは、外部のインサーキットエミュレータに、前 記第1のビット数より少ないビット数のツールバスと該ツールバスのステータス を通知するバスステータス信号線とを介して接続され、

更に, 前記デバッグサポートユニットは,

命令アドレスをパラレル・シリアル変換するパラレル・シリアル変換回路と,

前記CPUから受信した分岐信号と命令フェッチ要求信号に応答して分岐情報 と命令フェッチ要求を有するステータス情報信号を生成するステータス情報生成 回路と、

前記ステータス情報信号に応答して前記バスステータス信号線に命令アドレス 出力信号を出力するステータス出力回路と,

前記ステータス情報信号に応答して前記変換された命令アドレスを前記ツール バスにシリアルに出力するデータ出力回路とを有し,

前記ステータス情報生成回路は、次の命令フェッチ要求を受信する前に、現在の命令フェッチ要求に対応した命令コードの受信を完了した時、当該現在の命令フェッチ要求の命令アドレスに続く命令アドレスに対する命令プリフェッチ要求のためのプリフェッチステータス情報信号を生成することを特徴とするマイクロコントローラ。

【請求項4】請求項3において、

前記ステータス情報生成回路は、前記命令プリフェッチ要求を開始した後、前記CPUから命令フェッチ要求を受け付けて分岐有りの分岐信号を受信したとき、前記命令プリフェッチ要求についての制御をキャンセルすることを特徴とするマイクロコントローラ。

【請求項5】請求項3において,

前記データ出力回路は、前記プリフェッチステータス情報信号に応答して、命

令アドレスに代えて分岐なし信号を前記ツールバスに出力することを特徴とする マイクロコントローラ。

【請求項6】請求項3において,

前記ステータス情報生成回路は、前記ツールバスが使用中でなく、前記インサーキットエミュレータから受信される命令コードを格納するバッファに空きがあるとき、前記プリフェッチステータス情報信号を生成することを特徴とするマイクロコントローラ。

【請求項7】CPUとバスコントローラを内蔵するマイクロコントローラにおいて、

前記CPUとバスコントローラとを接続する第1のビット数のアドレスバスと

前記アドレスバスが接続されたデバッグサポートユニットとを有し、

前記デバッグサポートユニットは、外部のインサーキットエミュレータに、前 記第1のビット数より少ないビット数のツールバスと該ツールバスのステータス を通知するバスステータス信号線とを介して接続され、

更に、前記デバッグサポートユニットは、

アドレスに含まれる有効アドレスと当該有効アドレスの有効桁数信号とを有す るエンコードアドレスを出力するエンコーダと,

前記エンコードアドレスをパラレル・シリアル変換するパラレル・シリアル変 換回路と,

前記CPUから受信した命令フェッチ要求信号またはデータアクセス要求信号 に応答して、命令フェッチ要求またはデータアクセス要求を有するステータス情報信号を前記有効桁数サイクル期間生成するステータス情報生成回路と、

前記ステータス情報信号に応答して,前記バスステータス信号線にアドレス出力信号を出力するステータス出力回路と,

前記ステータス情報信号に応答して、前記エンコードアドレスを前記ツールバスにシリアルに出力するデータ出力回路とを有するマイクロコントローラ。

【請求項8】CPUとバスコントローラを内蔵するマイクロコントローラにおいて、

前記CPUとバスコントローラとを接続し命令アドレスをパラレルに転送する 第1のビット数の命令アドレスバスと,

前記命令アドレスバス接続されたデバッグサポートユニットとを有し、

前記デバッグサポートユニットは、外部のインサーキットエミュレータに、前 記第1のビット数より少ないビット数のツールバスと該ツールバスのステータス を通知するバスステータス信号線とを介して接続され、

更に、前記デバッグサポートユニットは、前記CPUから受信した命令フェッチ要求が分岐あり命令の場合は、命令アドレスをパラレル・シリアル変換して、当該変換された命令アドレスを前記ツールバスにシリアルに出力し、前記命令フェッチ要求が分岐なし命令の場合は、分岐なし信号を前記ツールバスに出力することを特徴とするマイクロコントローラ。

【請求項9】CPUとバスコントローラを内蔵するマイクロコントローラにおいて、

前記CPUとバスコントローラとを接続し命令アドレスをパラレルに転送する 第1のビット数の命令アドレスバス及び命令コードバスと,

前記命令アドレスバスと命令コードバスとが接続されたデバッグサポートユニットとを有し,

前記デバッグサポートユニットは、外部のインサーキットエミュレータに、前 記第1のビット数より少ないビット数のツールバスと該ツールバスのステータス を通知するバスステータス信号線とを介して接続され、

更に、前記デバッグサポートユニットは、前記CPUから受信した命令フェッチ要求信号に応答して前記命令アドレスを前記ツールバスにシリアルに出力し、次の命令フェッチ要求を受信する前に当該命令フェッチ要求に対応する命令コードを前記インサーキットエミュレータから受信した時に、命令プリフェッチ制御を開始することを特徴とするマイクロコントローラ。

【請求項10】CPUとバスコントローラを内蔵するマイクロコントローラにおいて、

前記CPUとバスコントローラとを接続する第1のビット数のアドレスバスと

前記アドレスバスが接続されたデバッグサポートユニットとを有し、

前記デバッグサポートユニットは、外部のインサーキットエミュレータに、前 記第1のビット数より少ないビット数のツールバスと該ツールバスのステータス を通知するバスステータス信号線とを介して接続され、

更に, 前記デバッグサポートユニットは,

アドレスに含まれる有効アドレスと当該有効アドレスの有効桁数信号とを有するエンコードアドレスを生成し、前記CPUから受信した命令フェッチ要求信号またはデータアクセス要求信号に応答して、前記エンコードアドレスを前記ツールバスにシリアルに出力するデータ出力回路とを有するマイクロコントローラ。

# 【発明の詳細な説明】

[0001]

# 【発明の属する技術分野】

本発明は、デバッグサポートユニット(以下DSU)を有するマイクロコントローラに関し、特に、デバッグ用のプログラムやデータを記憶し、プログラムの命令コード実行時におけるCPUの状態をモニタする機能を有するインサーキットエミュレータ (ICE) に対して、命令フェッチやデータアクセスを高速に行うことができるDSUを有するマイクロコントローラに関する。

[0002]

# 【従来の技術】

コンピュータの周辺機器や家電などの被制御装置に組み込まれるマイクロコントローラは、制御プログラムやデータを記録した外付けのメモリと外部バスを介して接続され、そのメモリに対して命令フェッチ要求を出して命令コードを読み出し、データアクセス要求を出して所定のデータを読み出しまたは書き込みする

[0003]

かかるマイクロコントローラでは、開発段階でのデバッグ工程で、制御プログラムやデータを記憶し、命令コード実行時のマイクロコントローラ内の状態をモニタするなどの機能を有するインサーキットエミュレータ (ICE) をマイクロコントローラに接続して、エミュレータモードで動作させることが行われる。この

エミュレータモードでの動作を可能にするために、開発段階のマイクロコントローラ内にはICEへのアクセスを制御するデバッグサポートユニット (DSU) が内蔵される。

[0004]

マイクロコントローラは、CPUに加えて、外部バスとのアクセスのためにバスコントローラを内蔵する。そして、CPUとバスコントローラとは、多ビット構成のアドレスバスやデータバスとで接続され、両者はアクセス時のアドレスやデータをパラレルに送受信することができる。これらのバスアーキテクチャは、CPU側が、バスコントローラからのウエイト信号が解除状態である時にアドレスと共にアクセス要求を出し、バスコントローラはそのアクセス要求を受け付けるとウエイト信号をウエイト状態にして外部にアクセスし、やがてアクセスされたデータや命令コードを取得すると、バスコントローラがCPUにそれらのデータや命令コードを送信して、ウエイト信号を解除するという、単純な構成をとるのが一般的である。

[0005]

このようなマイクロコントローラにおいて、上記のエミュレータモードでのデバッグを実施するためには、アドレスバスやデータバスをDSUにも接続し、DSUが外付けのICEとの間のアクセス制御を行うことが必要になる。つまり、DSUがCPUからのアクセス要求を取得してウエイト信号をウエイト状態にしてICEにアクセス要求を出し、ICEからデータや命令コードを取得したら、それをCPUに送信すると共にウエイト信号を解除する。

[0006]

【発明が解決しようとする課題】

しかしながら、外付けのICEは、プログラムやデータを記憶すると共に、マイクロコントローラの内部状態をモニタする機能を有する。かかる内部状態をモニタするための信号線の本数は、膨大な数に上り、それだけでマイクロコントローラの外部ピンの大部分を占めてしまう。その結果、DSUとICE間のデータやアドレスの転送用のツールバスに利用できる外部ピンの数には自ずと限界があり、かかるツールバスは、マイクロコントローラ内部のデータバスのように多くのビット

構成にすることはできない。そのため、DSUとICE間の少数ビット構成のツールバスを介して、アドレスやデータを時分割でシリアル転送しなければならない。

[0007]

والمستعلق المراجع المر

例えば、マイクロコントローラ内部のアドレスバスやデータバスは16ビット あるいは32ビット構成にして、アドレスやデータを1サイクルでパラレル転送 されるのに対して、DSUとICEとの間のツールバスは4ビット構成であり、DSUはC PUから受信した上記アドレスやデータをパラレル・シリアル変換して、ICEに時 分割でシリアル転送することになる。その後、DSUは、ICE側から受信した命令コードをシリアルパラレル変換し、CPU側に送信する。この一連の命令フェッチが 完了するまで、DSUはCPUに対してウエイト信号を送出してウエイトをかける。

[0008]

このようなデータ転送の制約は、エミュレートモード動作において、頻繁に命令フェッチが生じると、命令コードを取り込むだけでツールバスを大幅に占領してしまい、デバッグ処理のパフォーマンスが悪くなるという問題を招いてしまう

[0009]

そこで、本発明の目的は、ICEに対するアクセス制御を効率的に行うことができるDSUを内蔵したマイクロコントローラを提供することにある。

[0010]

更に、本発明の目的は、ICEへのツールバス幅が狭くても、エミュレータモードにおいて、CPUの命令フェッチやデータアクセスを効率的に行うことができるマイクロコントローラを提供することにある。

[0011]

【課題を解決するための手段】

上記の目的を達成するために、本発明の第1の側面は、マイクロコントローラにおいて、内部にCPUとバスコントローラとそれらを接続する第1のビット数の命令アドレスバスと第2のビット数の命令コードバスとを有し、更に、前記命令アドレスバスと命令コードバスが接続されたデバッグサポートユニットとを有し、前記デバッグサポートユニットは、外部のインサーキットエミュレータに、

前記第1のビット数より少ない第3のビット数のツールバスと該ツールバスのス テータスを通知するバスステータス信号線を介して接続される。

# [0012]

上記の構成において、デバッグサポートユニットは、命令アドレスをパラレル・シリアル変換するパラレル・シリアル変換回路と、前記CPUから受信した分岐信号と命令フェッチ要求信号に応答して分岐情報と命令フェッチ要求を有するステータス情報信号を生成するステータス情報生成回路と、ステータス情報信号に応答してバスステータス信号線に命令アドレス出力信号を出力するステータス出力回路と、前記ステータス情報信号に応答して、前記分岐情報が分岐有りの時は前記変換された命令アドレスを前記ツールバスにシリアルに出力し、分岐情報が分岐なしの時は分岐なし信号を前記ツールバスに出力するデータ出力回路とを有する。

# [0013]

かかるデバッグサポートユニットは、ICEへのアクセス制御において、分岐なしの命令フェッチ要求があった時は、ツールバスから命令アドレスをシリアルに複数サイクルの期間かけてICEに転送するのではなく、分岐なし信号を例えば1サイクルだけICEに転送する。従って、命令フェッチ要求における命令アドレスの転送効率を高くすることができる。

#### [0014]

上記の目的を達成するために、本発明の第2の側面は、上記第1の側面のマイクロコントローラと同様の構成において、デバッグサポートユニットは、命令アドレスをパラレル・シリアル変換するパラレル・シリアル変換回路と、CPUから受信した分岐信号と命令フェッチ要求信号に応答して分岐情報と命令フェッチ要求を有するステータス情報信号を生成するステータス情報生成回路と、ステータス情報信号に応答してバスステータス信号線に命令アドレス出力信号を出力するステータス出力回路と、ステータス情報信号に応答して前記変換された命令アドレスを前記ツールバスにシリアルに出力するデータ出力回路とを有し、前記ステータス情報生成回路は、次の命令フェッチ要求を受け付ける前に、現在の命令フェッチ要求に対応した命令コードの受信を完了した時、当該現在の命令フェッ

チ要求の命令アドレスに続く命令アドレスに対する命令プリフェッチ要求のため のプリフェッチステータス情報信号を生成することを特徴とする。

# [0015]

上記デバッグサポートユニットは、CPUに対してウエイト状態になっている間に現在の命令フェッチ要求に対するICEへの命令アドレス出力を完了すると、自発的に現在の命令アドレスに続く命令アドレスに対応する命令プリフェッチを実行する。かかるアクセス制御により、CPUへのウエイト状態が解除された後にCPUが分岐なしの命令フェッチ要求を出した場合は、デバッグサポートユニットは、既にプリフェッチした命令コードを短時間でもしくは即刻CPUに返信することができる。従って、バス幅が狭いツールバスの使用効率を高めることができる。

# [0016]

上記の第2の側面において、命令プリフェッチ要求のために、上記発明の第1の側面で説明したように、分岐なし信号と命令アドレス出力信号とをツールバスとバスステータス信号線にそれぞれ出力することが好ましい。これにより、無駄になるかも知れない命令プリフェッチを、少ないサイクルで行うことができる。

#### [0017]

更に、上記の第2の側面において、命令プリフェッチ要求のためにステータス情報信号を生成してICEへの命令プリフェッチ実行中に、CPUから分岐有りの命令フェッチ要求を受信した時は、ステータス情報生成回路は、前記命令プリフェッチ要求のためのステータス情報信号の生成を中止することが好ましい。

#### [0018]

上記の目的を達成するために、本発明の第3の側面は、上記第1の側面のマイクロコントローラと同様の構成において、デバッグサポートユニットは、アドレスに含まれる有効アドレスと当該有効アドレスの有効桁数信号とを有するエンコードアドレスを出力するエンコーダと、前記エンコードアドレスをパラレル・シリアル変換するパラレル・シリアル変換回路と、前記CPUから受信した命令フェッチ要求信号またはデータアクセス要求信号に応答して、命令フェッチ要求またはデータアクセス要求を有するステータス情報信号を前記有効桁数サイクルだ

け生成するステータス情報生成回路と、ステータス情報信号に応答してバスステータス信号線にアドレス出力信号を出力するステータス出力回路と、前記ステータス情報信号に応答して、前記エンコードアドレスを前記ツールバスにシリアルに出力するデータ出力回路とを有する。

[0.019]

上記のデバッグサポートユニットによれば、命令フェッチ要求やデータアクセス要求時に、有効アドレスに有効桁数を付加したエンコードされたアドレスをIC Eに転送するので、アドレス転送に必要なバスサイクルを短くすることができる

[0020]

# 【発明の実施の形態】

以下,図面を参照して本発明の実施の形態例を説明する。しかしながら,本発明の保護範囲は,以下の実施の形態例に限定されるものではなく,特許請求の範囲に記載された発明とその均等物にまで及ぶものである。

# [0021]

図1は、本実施の形態例におけるマイクロコントローラの構成を示す図である。マイクロコントローラ1は、CPU2とバスコントローラ3とデバッグサポートユニット(DSU)4とを有し、それらは、命令フェッチ要求信号6と32ビットの命令アドレスバス7と16ビットの命令コードバス8により接続される。更に、CPU、バスコントローラ、DSUの間には、データアクセス要求信号線9とデータアドレスバス10とデータバス11が設けられる。そして、命令系とデータ系それぞれに対して、命令ウエイト信号線12とデータウエイト信号線13とが設けられる。

[0022]

CPU 2 は、バスコントローラ3 に対して、命令フェッチ要求信号と命令アドレスを出力し、外部バス15 に接続される外部のメモリから命令コードをフェッチする。バスコントローラ3 は、命令フェッチ要求信号を受信すると命令ウエイト信号を返して、CPUをウエイト状態にし、命令コードを命令コードバス8 に出力するとウエイト状態を解除して、次の命令フェッチ要求信号を受け付ける。デー

タアクセス要求も同様にして行われる。

[0023]

マイクロコントローラ1は、デバッグ用のプログラムやマイクロコントローラ 内の状態を監視するためのトレース機能を有するICEとのインターフェースを行 うDSU4を内蔵する。そして、デバッグ工程では、CPUはDSUに対して命令フェッ チ要求やデータアクセス要求を出して、エミュレータモードで動作する。

[0024]

DSU4とICE5とは、命令コードバス8やデータバス11に比較して少ないビット数、例えば4ビットのツールバス16で接続されている。そして、DSU4は、3ビットのバスステータス信号線17により、ICE5に対してツールバス16の状態やツールバスに出力された信号の種類を出力する。

[0025]

バスステータス信号17により、非動作状態(ノーオペレーションNOP)と、命令アドレス、データリードアドレス、データライトアドレス、データ取り込みまたは命令コード取り込み、ライトデータの少なくとも6種類のツールバス状態がICEに通知される。

[0026]

トレース用信号線18は、100本以上になる場合があり、その結果、ツールバス16は、マイクロコントローラが内蔵する命令アドレスバス7やデータアドレスバス10に比較するとビット数が少ない。そのため、DSUは、CPUから送信されるアドレスをパラレル・シリアル変換して、ツールバスを介してICE5に4ビットづつシリアルに転送する。従って、命令フェッチ要求やデータアクセス要求が頻繁に繰り返されると、ツールバス16のビット数が少ないので、デバッグ処理のパフォーマンスが悪くなる。

[0027]

図2は、本実施の形態例の原理を説明するための図である。図2(A)にDSU内部のアクセス制御部の構成図、図2(B)にその動作タイミングチャート図、図2(C)に従来の動作タイミングチャート図をそれぞれ示す。

[0028]

DSUのアクセス制御部は、図2(A)に示されるとおり、CPUからの分岐信号14と命令フェッチ要求信号6とを受信して、分岐情報と命令フェッチ要求とを含むステータス情報信号S20を生成するステータス情報生成回路20と、ステータス情報信号S20に応答してバスステータス信号線17に命令アドレス出力信号を出力するステータス出力回路22と、CPUからパラレルに供給される32ビットの命令アドレスをパラレル・シリアル変換して、4ビットのアドレスをシリアルに出力するパラレル・シリアル変換回路24と、シリアルアドレスをツールバス16に出力するデータ出力回路28とを有する。分岐信号は、命令フェッチ対象の命令コードのアドレスが連続する時は分岐なし情報を、連続しない時は分岐有り情報を含む。CPU内部では通常、分岐のありなしを解析済みであるが、CPUがかかる分岐信号を出力しない場合は、DSU側で命令アドレスを比較することで検出することができる。

[0029]

ステータス情報生成回路 2 0 は、CPUが供給するフェッチ対象の命令が分岐有りの場合は、命令アドレスをシリアルに出力するために必要なバスサイクル数だけステータス情報信号S20を出力する。従って、ステータス情報生成回路 2 0 内には、カウンタが内蔵されている。一方、ステータス情報生成回路 2 0 は、分岐無しの場合は、ステータス情報信号S20は 1 バスサイクルのみしか出力しない。その場合、データ出力回路 2 8 は、ステータス情報信号S20が有する分岐なし情報に応答して、ツールバス 1 6 に、分岐なし信号を出力する。

[0030]

図2 (C) に示されるとおり、従来の命令フェッチ動作では、ステータス出力 回路 2 2 がバスステータス信号として、NOPの後の 4 番目のクロックから 1 1 番目のクロックまでの 8 バスサイクルの期間、アドレス出力信号を出力し、データ出力回路 2 8 が、パラレル・シリアル変換された 4 ビットの命令アドレスを、1サイクル遅れの 5 番目のクロックから 1 2 番目のクロックまで 1 2 回、ツールバス 1 6 にシリアル転送する。その後、ステータス出力回路 2 2 がバスステータス信号線 1 7 にデータ取り込み信号を 4 サイクル出力し、それに応答して、ICEが命令コードを 4 サイクルで返信する。ICEは、バスステータス信号のステータス





を参照して、対応する動作を行うので、ツールバスには、1クロック遅れでアド レスやデータが転送される。

[0031]

それに対して、本実施の形態例では、図2(B)に示されるとおり、ステータス情報生成回路20が分岐信号14から分岐無しであることを検出すると、分岐無し情報を含むステータス情報信号S20をデータ出力回路28とステータス出力回路22に出力するので、4、5番目のクロックで1サイクルのみ、アドレス出力信号と分岐無し信号とが、バスステータス信号線17とツールバス16とにそれぞれ出力される。それに続いて、データ取り込み信号がバスステータス17から出力され、それに応答して、1クロックサイクル遅れで、4サイクルにわたり命令コードが返信される。

[0032]

図3は、本実施の形態例の別の原理を説明するための図である。図3(A)の アドレス制御部の構成例に示されるとおり、ステータス情報生成回路20と、ス テータス出力回路22と,パラレル・シリアル変換回路24と,データ出力回路 28とを有し、更に、命令アドレス選択回路30を有する。この例では、CPUか らの命令フェッチ要求信号6に応答して,ステータス情報生成回路20がステー タス情報信号S20を出力して,命令フェッチ動作が完了した時点で,つまり,デ ータ出力回路28がツールバス16に対して命令アドレスをシリアル転送し,若 しくは分岐無し信号を出力した後、命令コードを受信した時点で、当該ステータ ス情報生成回路20が未だCPUから命令フェッチ信号を受信していなければ,図 示しないツールバス16の受信バッファに空きがある時に限り,命令プリフェッ チのために新たなステータス情報信号S20を出力する。この命令プリフェッチの ステータス情報信号S20は、分岐無し情報を含み、それに応答して、命令アドレ ス選択回路30は、CPUからの命令アドレスの代わりに、アドレスをプラス2し た次の命令アドレスを出力する。従って、次のアドレスの命令アドレスが、パラ レル・シリアル変換されてデータ出力回路28からツールバス16に出力される 。上記の例では、分岐なしの命令アドレスはプラス2づつインクリメントされる



[0033]

つまり、CPUからの命令フェッチ要求信号を受信していなくても、現在の命令フェッチ動作が完了したら、ツールバスが未使用状態になっているので、受信バッファに空きがある限り、ステータス情報生成回路20は命令プリフェッチ動作を開始する。そのため、ビット数が少ないツールバス16を効率的に使用でき、その後CPUから命令フェッチ要求信号が来た時は、より短いサイクルでまたは即刻命令データを返信することができる。

[0034]

上記の命令プリフェッチ動作は、図2に示した原理を利用して、ツールバス16から分岐無し信号を出力することにより、よりツールバスの使用効率を上げることができる。その場合は、図3の命令アドレス選択回路30は不要になる。

[0035]

命令プリフェッチは、CPUから送信される命令フェッチ要求が分岐命令か分岐 無し命令かを確認することなく行われる。従って、命令プリフェッチを実施中に CPUから次の分岐有りの命令フェッチ要求が来た場合は、前もって実施していた 命令プリフェッチ動作は無駄になるので、ステータス情報生成回路20が直ちに ステータス情報信号S20としてキャンセル情報を出力する。

[0036]

図3 (B) は、上記の命令プリフェッチ動作中にキャンセルが行われた場合の動作タイミングチャート図である。4番目のクロックでバスステータス信号線17にアドレス出力が出力され、次のクロックで分岐無し信号がツールバス16に出力されて命令プリフェッチ動作が開始している。それに続いて、6番目のクロックからデータ取り込み信号がバスステータスに出力され、2サイクルの間命令コードがツールバス16に返信された時点で、ステータス出力回路22がノーオペレーション信号NOPを出力することで、ツールバス16への命令コードの返信は停止される。ICEは、バスステータス17のステータス信号に応答して、次のサイクルで対応する命令コードやデータをツールバス16に出力する。従って、DSU側のアクセス制御部は、このNOP信号をバスステータスに出力することで、命令プリフェッチ動作をキャンセルすることができる。

# [0037]

図4は、本実施の形態例における更に別の原理を説明するための図である。命令フェッチ要求やデータアクセス要求において、DSUはアドレスをパラレル・シリアル変換してツールバス16に転送する必要がある。その場合、例えば下位アドレスは、上位ビットは「0」のみであり、下位ビットのみに有効なアドレスが含まれる。そこで、図4(A)に示されるとおり、エンコーダ32が、CPUから供給される命令アドレスを解析し、有効アドレスの桁数(厳密には転送サイクル数)と有効アドレスとにエンコードする。例えば、32ビットの命令アドレスが「0000888」(16進表示)の場合は、有効桁数3と有効アドレス「888」とからなるエンコードアドレス「3888」がエンコーダ32で生成される。そして、そのエンコードアドレスS32Aがパラレル・シリアル変換回路24に出力され、パラレル・シリアル変換されたアドレスが、データ出力回路28からツールバスに転送される。

# [0038]

このようにエンコードされたアドレスは、通常のアドレスの転送サイクル8よりもその転送サイクルが4と少ないので、エンコーダ32から有効桁数信号(TAG信号)S32Bがステータス情報生成回路20に供給され、ステータス情報生成回路20は、その有効桁数にプラス1したサイクル数の期間、ステータス情報信号S20を出力する。つまり、ステータス情報生成回路20に内蔵されるカウンタは、有効桁数にプラス1したサイクル数だけカウントしながら、ステータス情報信号S20を出力する。

### [0039]

図4 (B) は、上記の動作タイミングチャート図であり、4番目から8番目の4クロックサイクル期間、アドレス出力信号がバスステータス信号線17に出力され、それから1クロックずれた5番目から9番目の4クロックサイクル期間で、有効桁数信号のTAB出力と有効命令アドレスとがツールバス16経由でシリアルに出力される。ICEは、ツールバス16に転送された命令アドレスのサイクル数が通常の8サイクルよりも短いことで、エンコードアドレスであることを認識し、デコードして、32ビットの命令アドレスを生成し、命令フェッチを行う。

# [0040]

以上,本実施の形態例の原理を説明したが,次に,具体例を説明する。図5は,DSU4の構成例を示す図である。DSU4は,アクセス制御部40とウエイト制御部42とで構成される。命令フェッチ要求信号線6,命令アドレスバス7,分岐信号線14,データアクセス要求信号9,データバス10が,アクセス制御部40に接続され,ウエイト信号線12,13とデータバス,命令コードバス8,11がウエイト制御部42に接続される。

# [0041]

アクセス制御部40は、命令フェッチ要求信号と分岐信号に応答して、ICE5に対して命令フェッチを実行する。また、データアクセス要求信号に応答して、データリードまたはデータライトをICE5に対して実行する。アクセス制御部40は、命令フェッチ要求信号やデータアクセス要求信号を受け付けると、ステータス情報信号S20を生成し、ウエイト制御部42が、CPUに対してウエイト信号12、13を出力し、更なる要求信号の発行を禁止する。また、アクセス制御部40が、ICEから命令コードまたはデータを受信したら、ウエイト制御部42は、それらのデータをデータバスまたは命令コードバス11、8を介してCPUに転送すると共に、ウエイト信号を解除する。それによって、CPUは次の要求信号を発行することができる。

### [0042]

図6は、アクセス制御部40の詳細構成図である。アクセス制御部40は、入力バッファ44、46、48、50、52、54と出力バッファ56を有する。更に、命令フェッチ要求信号6と分岐信号14及びデータアクセス要求信号9とを入力し、アクセスの種類を判定するアクセス判定回路58を有する。アクセスの種類には、分岐なしの命令フェッチ要求、分岐ありの命令フェッチ要求、データリード要求、データライト要求とがある。アクセス判定回路の出力とエンコーダ32Aと32Bの有効桁数信号(TAG信号)S32A、S32Bとが、ステータス情報生成回路20に供給される。

#### [0043]

また、アクセス制御部40には、アドレスとデータを選択するアドレス・デー

タ選択回路 6 0 が設けられ、エンコードされた命令アドレスと、エンコードされたデータアドレスと、ライト用のデータとが、ステータス情報生成回路 2 0 が生成するステータス情報信号S20に応じて選択され、パラレル・シリアル変換回路 2 4 に供給される。

# [0044]

更に、データ入出力回路28が受信した命令コードや読み出しデータは、シリアル・パラレル変換回路62にてシリアル・パラレル変換されて、出力バッファ56からデータバス64を介して、ウエイト制御部42に出力される。また、ステータス情報信号S20は、ウエイト制御部42にも出力され、それに応答して、ウエイト信号が出力される。

# [0045]

図6のアクセス制御部40によれば、図2、3、4で説明した3種類のアクセス制御が全て実施される。つまり、分岐なし命令フェッチに対しては、ステータス出力回路22から1サイクルだけ命令アドレス出力信号がバスステータス信号線17に出力され、その次の1サイクルだけデータ入出力回路28からツールバス16に分岐なし信号が出力される。また、命令プリフェッチの場合も、上記と同様に分岐なし信号がツールバス16に出力される。そして、命令アドレス及びデータアドレスの両方が、エンコーダ32A、32Bにて有効桁数のTAG信号と有効アドレス信号とにエンコードされ、パラレル・シリアル変換回路24に供給され、更に、データ入出力回路28が、ツールバス16にTAG信号と有効アドレス信号とをシリアル転送する。

# [0046]

上記したアクセス制御によれば、ステータス情報生成回路20が生成するステータス情報信号S20に基づいて、ステータス出力回路22やデータ入出力回路28が対応するバスステータス信号やアドレス、データをICEに転送する。そこで、ステータス情報生成回路20を中心とするアクセス制御の動作をフローチャートに従って以下説明する。

# [0047]

図7は、アクセス制御部での内部動作を示すフローチャート図である。ステー

1 7

タス情報生成回路 2 0 は、アクセス制御のためにステータス情報信号を生成しているので、現在ツールバスが使用中か否かを知りうる立場にある。そこで、ステータス情報生成回路 2 0 は、ツールバスが使用中でなければ (P10)、データアクセス要求か、命令フェッチ要求のいずれかがCPUにより発行されたか否かをチェックする。CPUはウエイト信号によりウエイト状態が解除されている時のみ、上記の要求信号を発行する。また、図7に示されるとおり、データアクセス要求が優先的に処理される。

#### [0048]

データアクセス要求が発行されていたら、それに応答して、データアクセスを 実行する(P14)。また、命令フェッチ要求が発行されたら(P16)、分岐信号か ら分岐ありかなしかが判定され(P18)、分岐が発生していれば、分岐ありの命 令フェッチが実行される(P20)。また、分岐が発生していなければ、分岐なし 命令フェッチが実行される(P22)。

# [0049]

更に、ステータス情報生成回路 2 0 は、データアクセス要求も命令フェッチ要求もなく、また、データアクセスや命令フェッチが完了してツールバスが不使用状態の時、ウエイト制御部内の出力バッファに命令データを格納するための空きが存在していれば(P24)、プリフェッチのステータス情報信号を生成して、命令プリフェッチを実行さる(P26)。

# [0050]

図8は、データアクセスのフローチャート図である。データアクセス要求を受信するとデータアクセスが実行される。データアクセス要求が、データリードの場合は、ステータス情報信号S20に応答して、アドレス・データ選択回路60がエンコードされたデータアドレスを出力し、パラレル・シリアル変換されたデータアドレスが、データ入出力回路28から、ツールバス16を介してICEに出力される(S32)。それに続いて、ICEから出力されたリードデータが、データ入出力回路28に入力され(S34)、ウエイト制御部内のバッファに格納される(P36)。また、データアクセス要求がデータライトの場合は、ステータス情報信号S20に応答して、エンコードされパラレル・シリアルされたデータアドレスが、ツ

ールバス16に出力され(S38), その後, ライトデータがツールバス16に出力される(S40)。

[0051]

図9は、分岐あり命令フェッチのフローチャート図である。分岐あり命令フェッチの場合は、 TAGデータと有効アドレスからなるエンコードされた命令アドレスが、データ入出力回路 2 8 からツールバス 1 6 にシリアル出力される (P42)。エンコードされているので、転送サイクル数は、エンコードされない場合よりも短くなる。 ICEは、それに応答して、命令コードを返信し、データ入出力回路 2 8 が取り込み (P44), バッファに格納する (P46)。

[0052]

図10は、エンコーダでのエンコードのフローチャート図である。図10のフローチャートには、エンコードにより検出された有効桁数(TAG)の生成工程が示される。32ビットのアドレスは、16進法では8桁になる。ツールバスが4ビットづつ転送するので、この4ビットをアドレスブロックと定義して、有効なアドレスブロック数をTAGデータとする。

[0053]

図10に示されるとおり、入力された命令アドレスまたはデータアドレスを上位桁から解析し、最上位ビット31-28が0でなければ、8桁全てが有効となり、有効アドレスブロック数としてTAG=8を出力する(P50,P51)。最上位ビット31-28が0で次の上位ビット27-24が0でなければ、7桁が有効となり、有効アドレスブロック数としてTAG=7を出力する(P52,P53)。以下同様に、上位ビットが全て0であるときは、その残りの下位ビットのアドレスブロック数がTAGデータとして出力される。上位ビット31-4が0の場合は、有効アドレスブロック数は1となる(P64)。

[0054]

上記の例では、TAG=6以下の場合のみ、エンコードされたアドレスがシリアル転送され、TAG=7以上では、もとのアドレスがそのままシリアル転送される。

[0055]

図11は、分岐なし命令フェッチまたは命令プリフェッチのフローチャート図

である。分岐なし命令フェッチ及び命令プリフェッチは、共に分岐なしの命令フェッチ動作になる。図11には、特に命令プリフェッチのために分岐が発生したか否かの判断がステップ毎に行われる(P70,P72,P73,P74)。ステータス情報生成回路20が、分岐なしの命令アドレス出力を示すステータス情報信号S20を生成すると、それに応答して、ステータス出力回路22が、バスステータス信号線17にアドレス出力信号を出力し、その次のサイクルで、データ入出力回路28が、ツールバスに分岐なし信号を1サイクルのみ出力する(P71)。それに応答して、ICEが、次の命令アドレスに対応する命令コードを返信すると、データ入出力回路28が、命令コードを受信し(P73)、受信バッファに格納する(P75)

# [0056]

命令プリフェッチ動作中に、次の命令フェッチ要求に分岐が含まれていることを示す分岐信号を受信すると、即座にキャンセルされる。また、命令コードを受信した後では、キャンセルに伴いその受信した命令コードがクリアされる(P76)。

#### [0057]

分岐なし命令フェッチも、上記と同様の動作になる。但し、分岐なし命令フェッチの場合は、既に命令フェッチ要求を受信し、それが分岐なしであることが確 定しているので、分岐発生が生じることはない。

#### [0058]

図12は、ウエイト制御部でのウエイト制御のフローチャート図である。ウエイト制御は、基本的に、ウエイト解除状態でCPUが命令フェッチ要求やデータアクセス要求を発行すると、DSUがCPUに対してウエイトを発行し、受け付けた要求に対応するアクセス制御を実行する。そして、そのアクセス制御が終了すると、DSUはCPUに対してウエイトを解除して、次の要求の発行を許可する。

# [0059]

図12によれば、DSU内のウエイト制御部42内の受信バッファに命令コード またはデータが格納されている時(P80),それがデータリード要求に対応する ものなら、データウエイトを解除して、バッファ内のデータをCPUにパラレル出 力し、バッファをクリアする(P81,P82)。また、受信バッファ内が命令コードであるときは、CPUから発行済みの命令フェッチ要求に対する命令コードであれば、命令ウエイトを解除して、バッファ内の命令コードをCPUに出力し、バッファをクリアする(P83,P84)。更に、受信バッファ内に命令コードが格納されていても、それが命令プリフェッチに対応するもので、CPUから未だ命令フェッチ要求が出されていない場合は、その命令コードのCPUへの送信は行われない。

[0060]

次に、データリード要求を受け付けると(P85)、CPUに対してデータウエイトを発行し(P86)、そのデータリード制御を実行する。また、データライト要求を受け付けると(P87)、ツールバスが使用中であれば、CPUに対してデータウエイトを発行し(P88、P89)、ツールバスが空くまでデータライト制御を待機させる。ツールバスが使用中でない若しくは直ぐに未使用になることが予想されれば、データウエイトを解除して(P90)、受信したライトデータをツールバスからICEに転送する。

[0061]

更に、命令フェッチ要求を受け付けると(P91), 命令ウエイトをCPUに対して発行し(P92), 命令フェッチ制御を実行する。

[0062]

以下、本実施の形態例における命令プリフェッチ動作、データリード、データ ライト動作の具体例について、動作タイミングチャートにより説明する。

[0063]

図13は、分岐が発生しない時の命令プリフェッチ動作のタイミングチャート図である。この例では、3つの命令フェッチ要求が連続して発行された例である。なお、以下のクロックと状態の関係は、クロックの立ち上がりエッジを基準にして説明している。

[0064]

まず、命令アドレス#Aの命令フェッチ要求に対する命令コードが取り込まれると、5番目のクロックで命令プリフェッチのためのアドレス出力がバスステータス17に出力され、その1クロック後に分岐なし信号がツールバス16に出力

される。つまり、命令プリフェッチでは、現在の命令フェッチ要求のアドレスに続くアドレスの命令コードがフェッチされることを予想して、DSUが分岐なし信号を出力して、ICEに次のアドレスの命令コードを出力するよう要求する。

[0065]

DSUは、図示しない命令コードバス8経由で、取り込んだ命令コードをCPUに出力すると、7番目のクロックで命令ウエイトを解除し、次の命令フェッチ要求を取り込む。それに伴い命令アドレスバス7にはアドレス#Bが出力される。但し、既に命令プリフェッチにより次の命令フェッチ動作が始まっており、DSUは、引き続きデータ取り込み信号をバスステータス信号線17に出力しながら、命令コードを受信する。ICEは、分岐なし信号を受信した後、バスステータスのデータ取り込み信号に応答して4サイクルで16ビットの命令コードを受信する。このICEの動作は、固定的である。

[0066]

DSUは、命令コードの取り込みを完了すると、ツールバス16が空いているので、ウエイト制御部内の受信バッファに空きがあれば命令プリフェッチを開始する。このようにして、次の命令フェッチについても、その要求を受け付ける前に開始することで、ツールバスが空き状態のままになることをなくし、ツールバスの使用効率を高めることができる。その結果、命令フェッチ要求に対する命令コードが、短いサイクルでCPUに出力される。

[0067]

図14は、分岐が発生する時の命令プリフェッチ動作のタイミングチャート図である。この例では、DSUは分岐が発生してもキャンセルは行わない。命令アドレス#Aに対する命令フェッチ要求に対する命令コードの取り込みが終了すると、DSUは5番目のクロックでアドレス出力信号をバスステータスに出力し、分岐なし信号をツールバスに出力して、命令プリフェッチを開始する。それに続いて、DSUはデータ取り込み信号をバスステータスに出力し、命令コードを4サイクルかけてシリアルに取り込む。ここまでは、図13と同じ動作である。

[0068]

しかし、7番目のクロックで命令ウエイトを解除して、次の命令フェッチ要求

を受け付けると、分岐信号14が分岐あり(Hレベル)になっている。そこで、命令プリフェッチの命令コードの取り込みが終了すると、12番目のクロック以降に、DSUは命令アドレス#BをエンコードしたTAGデータと有効アドレスとをツールバスに出力し、18番目のクロックから再度命令コードを取り込む。この命令コードの取り込みが終了すると、23番目のクロックから再度命令プリフェッチのために、アドレス出力信号をバスステータスに、分岐なし信号をツールバスにそれぞれ出力する。

[0069]

図14の例では、CPUは、分岐あり命令フェッチ要求を連続して発行することが禁止されている。その結果、命令アドレス#Bに対する2回の命令コード取り込み動作が、毎回繰り返されることが防止されている。

[0070]

図15は、分岐が発生する時の命令プリフェッチにおいてそれがキャンセルされる動作のタイミングチャート図である。この例では、DSUが分岐信号で分岐ありを検出すると、バスステータスにNOP信号を出力して、それまでの命令プリフェッチ動作をキャンセルする。

[0071]

この例では、命令アドレス#Aに対する命令コードの取り込みが終了すると、DSUは5番目のクロックでアドレス出力をバスステータスに出力し、6番目のクロックで分岐なし信号をツールバスに出力し、命令プリフェッチを開始する。DSUが図示しない受信バッファから命令コードをCPUにパラレス出力すると、7番目のクロックで命令ウエイトを解除し、命令アドレス#Bを受け付ける。そのとき、DSUは分岐信号14に分岐あり情報が含まれていることを検出し、既に始めていたデータ取り込み信号の出力を停止して、バスステータス17にNOP信号を出力する。それに応答して、ICEは命令プリフェッチに対する命令コードの出力を停止する。

[0072]

そして、DSUは、10番目のクロックからバスステータス17にアドレス出力信号を出力し、11番目のクロックでTAGデータを12番目のクロックから4サー

イクルで有効命令アドレスをツールバスから出力する。それ以降の動作は、図1 4の場合と同じである。

[0073]

図15の場合は、命令プリフェッチに対する命令フェッチ要求を受け付けた時に分岐ありであることが判明すると、DSUが先に始めた命令プリフェッチ動作をキャンセルするので、再度命令コードのフェッチを行っても、それによる遅れは、図14の場合よりも少ない。

[0074]

図16は、命令フェッチとデータリード動作のタイミングチャート図である。命令アドレス#Bに対する命令コードの取込が終了すると、5番目のクロックから、受付済みのデータアクセス要求(リード要求R)に対するデータアドレス#1に対するデータリード制御が始まる。即ち、DSUは、5番目のクロックからアドレス出力信号をバスステータス17に出力し、6番目のクロックからエンコードされたデータアドレスをTAGデータと共にツールバス16に出力する。更に、DSUは9番目のクロックからデータ入力信号をバスステータスに出力し、1クロック後にリードデータをツールバスから取り込む。図16には、簡略化のためにリードデータが2サイクルで取り込まれているが、リードデータが16ビットであれば、データ取り込みには4サイクルが必要である。

[0075]

DSUは7番目のクロックで命令ウエイトを解除して、次の命令フェッチ要求を受け付ける。この命令フェッチ要求は分岐なしであるので、DSUは、リードデータの取り込みが終了した後の12番目のクロックでアドレス出力信号をバスステータスに出力し、その次のクロックで分岐なし信号をツールバスに出力して、命令アドレス#Cに対する命令フェッチ制御を行う。更に、DSUは、ICEから取り込んだリードデータをデータバス11からCPUにパラレルに出力すると、14番目のクロックでデータウエイトを解除する。

[0076]

図17は、命令フェッチとデータライト動作のタイミングチャート図である。 この例では、図16の場合と同様に命令アドレス#Bに対する命令コードの取り 込みを終了すると、既に受け付けていたデータライト要求Wの制御を開始する。DSUは、アドレス出力信号をバスステータスに出力し、その1クロック後からTAGデータと有効データアドレスとをツールバスから出力する。それに続いて、DSUは9番目のクロックからデータ出力信号をバスステータスに出力し、ライトデータをツールバスに出力する。ここでも、簡単のためにライトデータの転送は2サイクルで終了している。

# [0077]

DSUは、ライトデータの転送を始めると、やがてツールバスが空くことを予想して、10番目のクロックでデータウエイトを解除している。ライトデータの出力が終了すると、12番目のクロックの立ち上がりエッジからアドレス出力信号をバスステータスに出力し、分岐なし信号をツールバスに出力して、命令アドレス#Cの命令フェッチを介しする。

# [0078]

尚、ツールバスでは、DSUからのアドレスやデータの出力と、ICEからの命令コードやリードデータの出力との間に、1クロックサイクルのNOP状態が生成され、それによりツールバスでのデータのコンフリクトが防止される。図17の例では、8番目のクロックでバスステータスにNOP信号が出力されて、9番目のクロックでツールバスには何もデータが出力されない状態になっている。しかし、DSUによるデータアドレスの出力とライトデータの出力との間には、データコンフリクトの問題はないので、NOP状態を生成する必要はない。

# [0079]

以上説明したとおり、本実施の形態例では、開発用のマイクロコントローラに 内蔵される、ICEとのインターフェースを行うDSUに、命令アドレスに代えて分岐 なし信号を出力して命令フェッチサイクルを短縮する機能と、ツールバスが空い ていれば命令プリフェッチ制御を行う機能と、命令アドレスやデータアドレスを TAGデータと有効アドレスとからなるエンコードアドレスにしてICEに出力して命令フェッチサイクルを短縮する機能とを搭載する。それにより、限られたビット 数しか持ち得ないツールバスであっても、その使用効率を上げて、デバッグ処理 におけるICEへのアクセス制御のパフォーマンスを上げることができる。 [0080]

以上、実施の形態例をまとめると以下の付記の通りである。

[0081]

(付記1) CPUとバスコントローラを内蔵するマイクロコントローラにおいて

前記CPUとバスコントローラとを接続する第1のビット数の命令アドレスバス及び命令コードバスと、

前記命令アドレスバスと命令コードバスとが接続されたデバッグサポートユニットとを有し,

前記デバッグサポートユニットは、外部のインサーキットエミュレータに、前 記第1のビット数より少ないビット数のツールバスと該ツールバスのステータス を通知するバスステータス信号線とを介して接続され、

更に, 前記デバッグサポートユニットは,

命令アドレスをパラレル・シリアル変換するパラレル・シリアル変換回路と,

前記CPUから受信した分岐信号と命令フェッチ要求信号に応答して分岐情報と命令フェッチ要求を有するステータス情報信号を生成するステータス情報生成回路と、

ステータス情報信号に応答して前記バスステータス信号線に命令アドレス出力 信号を出力するステータス出力回路と,

前記ステータス情報信号に応答して、前記分岐情報が分岐有りの時は前記変換された命令アドレスを前記ツールバスにシリアルに出力し、分岐情報が分岐なしの時は分岐なし信号を前記ツールバスに出力するデータ出力回路とを有することを特徴とするマイクロコントローラ。

[0082]

(付記2)付記1において,

前記データ出力回路は,前記分岐情報が分岐有りの時は,前記変換された命令 アドレスを前記ツールバスに複数サイクルにわたりシリアルに出力し,分岐情報 が分岐なしの時は前記分岐なし信号を前記ツールバスに1サイクルで出力するこ とを特徴とするマイクロコントローラ。 [0083]

(付記3)付記1において,

前記デバッグサポートユニットは、前記命令フェッチに対応するアドレス出力を出力した後、所定の複数サイクルの期間データ取り込み信号を前記バスステータス信号線に出力し、前記インサーキットエミュレータから前記命令フェッチに対応する命令コードをシリアルに受信することを特徴とするマイクロコントローラ。

[0084]

(付記4)付記1において,

前記デバッグサポートユニットは、前記CPUからの命令フェッチ要求を受け付けた時に、前記CPUに対してウエイト信号を発行し、当該命令フェッチ要求に対応する命令コードを前記CPUに対して返信した時に、前記ウエイト信号を解除することを特徴とするマイクロコントローラ。

[0085]

(付記5)付記1において,

前記デバッグサポートユニットは、前記CPUから命令フェッチ要求とデータアクセス要求とを受け付けた場合、前記データアクセス要求を優先的に処理することを特徴とするマイクロコントローラ。

[0086]

(付記 6) CPUとバスコントローラを内蔵するマイクロコントローラにおいて

前記CPUとバスコントローラとを接続する第1のビット数の命令アドレスバス及び命令コードバスと、

前記命令アドレスバスと命令コードバスとが接続されたデバッグサポートユニットとを有し,

前記デバッグサポートユニットは、外部のインサーキットエミュレータに、前 記第1のビット数より少ないビット数のツールバスと該ツールバスのステータス を通知するバスステータス信号線とを介して接続され、

更に、前記デバッグサポートユニットは、

命令アドレスをパラレル・シリアル変換するパラレル・シリアル変換回路と、 前記CPUから受信した分岐信号と命令フェッチ要求信号に応答して分岐情報 と命令フェッチ要求を有するステータス情報信号を生成するステータス情報生成

回路と,

前記ステータス情報信号に応答して前記バスステータス信号線に命令アドレス 出力信号を出力するステータス出力回路と,

前記ステータス情報信号に応答して前記変換された命令アドレスを前記ツール バスにシリアルに出力するデータ出力回路とを有し,

前記ステータス情報生成回路は、次の命令フェッチ要求を受信する前に、現在の命令フェッチ要求に対応した命令コードの受信を完了した時、当該現在の命令フェッチ要求の命令アドレスに続く命令アドレスに対する命令プリフェッチ要求のためのプリフェッチステータス情報信号を生成することを特徴とするマイクロコントローラ。

[0087]

(付記7)付記6において,

前記ステータス情報生成回路は、前記命令プリフェッチ要求を開始した後、前記CPUから命令フェッチ要求を受け付けて分岐有りの分岐信号を受信したとき、前記命令プリフェッチ要求についての制御をキャンセルすることを特徴とするマイクロコントローラ。

. [0088]

(付記8)付記6において,

前記データ出力回路は、前記プリフェッチステータス情報信号に応答して、命令アドレスに代えて分岐なし信号を前記ツールバスに出力することを特徴とするマイクロコントローラ。

[0089]

(付記9)付記6において、

前記ステータス情報生成回路は、前記ツールバスが使用中でなく、前記インサーキットエミュレータから受信される命令コードを格納するバッファに空きがあるとき、前記プリフェッチステータス情報信号を生成することを特徴とするマイ

クロコントローラ。

[0090]

(付記10)付記6において,

前記デバッグサポートユニットは、前記CPUからの命令フェッチ要求を受け付けた時に、前記CPUに対してウエイト信号を発行し、当該命令フェッチ要求に対応する命令コードを前記CPUに対して返信した時に、前記ウエイト信号を解除することを特徴とするマイクロコントローラ。

[0091]

(付記11) CPUとバスコントローラを内蔵するマイクロコントローラにおいて,

前記CPUとバスコントローラとを接続する第1のビット数のアドレスバスと

前記アドレスバスが接続されたデバッグサポートユニットとを有し、

前記デバッグサポートユニットは、外部のインサーキットエミュレータに、前 記第1のビット数より少ないビット数のツールバスと該ツールバスのステータス を通知するバスステータス信号線とを介して接続され、

更に、前記デバッグサポートユニットは、

アドレスに含まれる有効アドレスと当該有効アドレスの有効桁数信号とを有す るエンコードアドレスを出力するエンコーダと,

前記エンコードアドレスをパラレル・シリアル変換するパラレル・シリアル変 換回路と,

前記CPUから受信した命令フェッチ要求信号またはデータアクセス要求信号 に応答して、命令フェッチ要求またはデータアクセス要求を有するステータス情報信号を前記有効桁数サイクル期間生成するステータス情報生成回路と、

前記ステータス情報信号に応答して,前記バスステータス信号線にアドレス出力信号を出力するステータス出力回路と,

前記ステータス情報信号に応答して、前記エンコードアドレスを前記ツールバスにシリアルに出力するデータ出力回路とを有するマイクロコントローラ。

[0092]

(付記12) 付記11において,

前記アドレスバスは、命令アドレスバスとデータアドレスバスとを有し、前記 エンコーダは、前記命令アドレスバスとデータアドレスバスを介して入力するア ドレスをエンコードすることを特徴とするマイクロコントローラ。

[0093]

(付記13) CPUとバスコントローラを内蔵するマイクロコントローラにおいて,

前記CPUとバスコントローラとを接続し命令アドレスをパラレルに転送する 第1のビット数の命令アドレスバスと,

前記命令アドレスバス接続されたデバッグサポートユニットとを有し、

前記デバッグサポートユニットは、外部のインサーキットエミュレータに、前 記第1のビット数より少ないビット数のツールバスと該ツールバスのステータス を通知するバスステータス信号線とを介して接続され、

更に、前記デバッグサポートユニットは、前記CPUから受信した命令フェッチ要求が分岐あり命令の場合は、命令アドレスをパラレル・シリアル変換して、当該変換された命令アドレスを前記ツールバスにシリアルに出力し、前記命令フェッチ要求が分岐なし命令の場合は、分岐なし信号を前記ツールバスに出力することを特徴とするマイクロコントローラ。

[0094]

(付記14) CPUとバスコントローラを内蔵するマイクロコントローラにおいて,

前記CPUとバスコントローラとを接続し命令アドレスをパラレルに転送する 第1のビット数の命令アドレスバス及び命令コードバスと,

前記命令アドレスバスと命令コードバスとが接続されたデバッグサポートユニットとを有し,

前記デバッグサポートユニットは、外部のインサーキットエミュレータに、前 記第1のビット数より少ないビット数のツールバスと該ツールバスのステータス を通知するバスステータス信号線とを介して接続され、

更に、前記デバッグサポートユニットは、前記CPUから受信した命令フェッ

チ要求信号に応答して前記命令アドレスを前記ツールバスにシリアルに出力し、 次の命令フェッチ要求を受信する前に当該命令フェッチ要求に対応する命令コー ドを前記インサーキットエミュレータから受信した時に、命令プリフェッチ制御・ を開始することを特徴とするマイクロコントローラ。

[0095]

(付記15)付記14において,

前記デバッグサポートユニットは、前記命令プリフェッチ制御中に、前記CP Uから分岐有りの命令フェッチ要求を受付たら、当該命令プリフェッチ制御をキャンセルして、分岐先命令アドレスを前記ツールバスにシリアル転送することを 特徴とするマイクロコントローラ。

[0096]

(付記16)CPUとバスコントローラを内蔵するマイクロコントローラにおいて,

前記CPUとバスコントローラとを接続する第1のビット数のアドレスバスと

前記アドレスバスが接続されたデバッグサポートユニットとを有し、

前記デバッグサポートユニットは、外部のインサーキットエミュレータに、前 記第1のビット数より少ないビット数のツールバスと該ツールバスのステータス を通知するバスステータス信号線とを介して接続され、

更に, 前記デバッグサポートユニットは,

アドレスに含まれる有効アドレスと当該有効アドレスの有効桁数信号とを有するエンコードアドレスを生成し、前記CPUから受信した命令フェッチ要求信号 またはデータアクセス要求信号に応答して、前記エンコードアドレスを前記ツー ルバスにシリアルに出力するデータ出力回路とを有するマイクロコントローラ。

[0097]

【発明の効果】

以上、本発明によれば、開発中のマイクロコントローラに内蔵されるデバッグ サポートユニットが、外付けのインサーキットエミュレータとのアクセス制御を 効率的におこなうので、デバッグ処理のパフォーマンスを向上させることができ る。

#### 【図面の簡単な説明】

【図1】

本実施の形態例におけるマイクロコントローラの構成を示す図である。

【図2】

本実施の形態例の原理を説明するための図である。

【図3】

本実施の形態例における別の原理を説明するための図である。

【図4】

本実施の形態例における更に別の原理を説明するための図である。

【図5】

DSU4の構成例を示す図である。

【図6】

アクセス制御部40の詳細構成図である。

【図7】

アクセス制御部での内部動作を示すフローチャート図である。

【図8】

データアクセスのフローチャート図である。

【図9】

分岐あり命令フェッチのフローチャート図である。

【図10】

エンコーダでのエンコードのフローチャート図である。

【図11】

分岐なし命令フェッチまたは命令プリフェッチのフローチャート図である。

【図12】

ウエイト制御部でのウエイト制御のフローチャート図である。

【図13】

分岐が発生しない時の命令プリフェッチ動作のタイミングチャート図である。

【図14】

分岐が発生する時の命令プリフェッチ動作のタイミングチャート図である。

#### 【図15】

分岐が発生する時の命令プリフェッチでありキャンセルされる動作のタイミングチャート図である。

#### 【図16】

命令フェッチとデータリード動作のタイミングチャート図である。

#### 【図17】

命令フェッチとデータライト動作のタイミングチャート図である。

#### 【符号の説明】

- 1 マイクロコントローラ
- 2 CPU
- 3 バスコントローラ
- 4 デバッグサポートユニット
- 5 インサーキットエミュレータ
  - 6 命令フェッチ要求信号線
  - 7 命令アドレスバス
  - 12 命令ウエイト信号線
  - 14 分岐信号線
  - 16 ツールバス
  - 17 バスステータス信号線

【書類名】 図面

# 【図1】



### 【図2】

(A)



(B)



(C)



### 【図3】

(A)



(B)



### 【図4】

(A)



(B)



# 【図5】



### 【図6】



### 【図7】



# 【図8】



# 【図9】



### 【図10】



# 【図11】



【図12】



【図13】

### 分岐が発生しない時の命令プリフェッチ動作例



【図14.】

### 分岐が発生する時の命令プリフェッチ動作例 (命令プリフェッチキャンセルなし)





【図15】

### 分岐が発生する時の命令プリフェッチ動作例 (命令プリフェッチキャンセルあり)





【図16】

## 命令フェッチとデータアクセス動作例 (データリードの場合)



【図17】

# 命令フェッチとデータアクセス動作例 (データライトの場合)



【書類名】

要約書

【要約】

【課題】開発中のマイクロコントローラに内蔵されるデバッグサポートユニットが、外付けのインサーキットエミュレータとのアクセス制御を効率的におこなってデバッグ処理のパフォーマンスを向上させる。

【解決手段】マイクロコントローラにおいて、内部にCPUとバスコントローラとそれらを接続する第1のビット数の命令アドレスバスと命令コードバスとを有し、更に、命令アドレスバスと命令コードバスが接続されたデバッグサポートユニットとを有し、デバッグサポートユニットは、外部のインサーキットエミュレータに、第1のビット数より少ない第3のビット数のツールバスと該ツールバスのステータスを通知するバスステータス信号線を介して接続される。そして、デバッグサポートユニットは、CPUから受信した命令フェッチ要求が分岐あり命令の場合は、命令アドレスをパラレル・シリアル変換して、当該変換された命令アドレスをツールバスにシリアルに出力し、命令フェッチ要求が分岐なし命令の場合は、分岐なし信号をツールバスに出力する

【選択図】図2

#### 認定・付加情報

特許出願の番号

特願2001-189750

受付番号

50100908893

書類名

特許願

担当官

佐藤 浩聡

7664

作成日

平成13年 7月 3日

<認定情報・付加情報>

【特許出願人】

【識別番号】

000005223

【住所又は居所】

神奈川県川崎市中原区上小田中4丁目1番1号

【氏名又は名称】

富士通株式会社

【代理人】

申請人

【識別番号】

100094525

【住所又は居所】

神奈川県横浜市港北区新横浜3-9-5 第三東

昇ビル3階 林・土井 国際特許事務所

【氏名又は名称】

土井 健二

【代理人】

【識別番号】

100094514

【住所又は居所】

神奈川県横浜市港北区新横浜3-9-5 第三東

昇ビル3階 林・土井 国際特許事務所

【氏名又は名称】

林 恒徳

#### 出願人履歷情報

識別番号

[000005223]

1. 変更年月日

1996年 3月26日.

[変更理由]

住所変更

住 所

神奈川県川崎市中原区上小田中4丁目1番1号

氏 名

富士通株式会社